- 使用AspectJ AOP的注解方式@Transactional
- @Transactional有以下参数
参数 |
描述 |
readOnly |
该属性用于设置当前事务是否为只读事务,设置为true表示只读,false则表示可读写,默认值为false。例如:@Transactional(readOnly=true) |
propagation |
该属性用于设置事务的传播行为,具体取值可参考表6-7。 例如:@Transactional(propagation=Propagation.NOT_SUPPORTED,readOnly=true) |
isolation |
该属性用于设置底层数据库的事务隔离级别,事务隔离级别用于处理多事务并发的情况,通常使用数据库的默认隔离级别即可,基本不需要进行设置 |
timeout |
该属性用于设置事务的超时秒数,默认值为-1表示永不超时 |
rollbackFor |
该属性用于设置需要进行回滚的异常类数组,当方法中抛出指定异常数组中的异常时,则进行事务回滚。可用于指定特定异常都情况下进行回滚,例如: 指定单一异常类:@Transactional(rollbackFor=RuntimeException.class) 指定多个异常类:@Transactional(rollbackFor={RuntimeException.class, Exception.class}) |
rollbackForClassName |
该属性用于设置需要进行回滚的异常类名称数组,当方法中抛出指定异常名称数组中的异常时,则进行事务回滚。例如: 指定单一异常类名称:@Transactional(rollbackForClassName="RuntimeException") 指定多个异常类名称:@Transactional(rollbackForClassName={"RuntimeException","Exception"}) |
noRollbackFor |
该属性用于设置不需要进行回滚的异常类数组,当方法中抛出指定异常数组中的异常时,不进行事务回滚。例如: 指定单一异常类:@Transactional(noRollbackFor=RuntimeException.class) 指定多个异常类:@Transactional(noRollbackFor={RuntimeException.class, Exception.class}) |
noRollbackForClassName |
该属性用于设置不需要进行回滚的异常类名称数组,当方法中抛出指定异常名称数组中的异常时,不进行事务回滚。例如: 指定单一异常类名称:@Transactional(noRollbackForClassName="RuntimeException") 指定多个异常类名称: @Transactional(noRollbackForClassName={"RuntimeException","Exception"}) |
- 使用@Transactional注解需要先在applicationContext.xml中引入事务的命名空间
xmlns:tx="http://www.springframework.org/schema/tx"
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx.xsd
- 启用事务:用注解驱动的方式来管理事务
<tx:annotation-driven transaction-manager="transactionManager" />
- 在 applicationContext.xml 中配置事务管理器 : id=" transcationManager "
<!-- id="transactionManager" id名必须是transactionManager --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource" /> </bean>
|
- 在要使用事务的方法或类上,添加注解 @Transcational,spring会自动提交,回滚事务
示例
- applicationContext.xml
<context:annotation-config /> <context:component-scan base-package="com.bluesky" /> <tx:annotation-driven transaction-manager="transactionManager" /> <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <property name="configLocation" value="classpath:hibernate.cfg.xml" /> <property name="configurationClass" value="org.hibernate.cfg.AnnotationConfiguration" /> </bean> <!-- 定义事务管理器(声明式的事务) --> <bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory" /> </bean>
|
- UserDaoImpl.java
//在DAO上需加上@Transactional注解 //加在方法上,表示此方法受事务管理(自动提交,回滚事务) //加在类上,那么这个类中的所有方法都受事务管理 @Transactional @Component("userDao") public class UserDaoImpl extends HibernateDaoSupport implements UserDao{
public List<User> listUsers() { return this.getSession().createQuery("from User").list(); } } |
注
在业务方法中不要自己try-catch捕获异常,否则spring无法自动回滚事务
@Transactional的事务属性
事务超时 |
说明 |
@Transactional(timeout=30) |
默认是-1秒 |
传播行为 |
说明 |
@Transactional(propagation=Propagation.REQUIRED) |
如果有事务, 那么加入事务, 没有的话新建一个(默认情况) |
@Transactional(propagation=Propagation.NOT_SUPPORTED) |
容器不为这个方法开启事务 |
@Transactional(propagation=Propagation.REQUIRES_NEW) |
不管是否存在事务,都创建一个新的事务,原来的挂起,新的执行完毕,继续执行老的事务 |
@Transactional(propagation=Propagation.MANDATORY) |
必须在一个已有的事务中执行,否则抛出异常 |
@Transactional(propagation=Propagation.NEVER) |
必须在一个没有的事务中执行,否则抛出异常(与Propagation.MANDATORY相反) |
@Transactional(propagation=Propagation.SUPPORTS) |
如果其他bean调用这个方法,在其他bean中声明事务,那就用事务。如果其他bean没有声明事务,那就不用事务 |
隔离级别 |
说明 |
@Transactional(isolation = Isolation.READ_UNCOMMITTED) |
读取未提交数据(会出现脏读, 不可重复读),基本不使用 |
@Transactional(isolation = Isolation.READ_COMMITTED) |
(SQLSERVER默认) 读取已提交数据(会出现不可重复读和幻读) |
@Transactional(isolation = Isolation.REPEATABLE_READ) |
可重复读(会出现幻读) |
@Transactional(isolation = Isolation.SERIALIZABLE) |
串行化 |